import { get, post, postWithQueryParams } from "@/api/request";

/**
 * 设计概算 控制器 / 设计概算 控制器添加设计概算
 * @param {object} data
 * @param {string} [data.actualCompletionTime] 实际完成时间 YYYY-MM-DD HH:mm:ss
 * @param {array<number>} [data.attachList] 附件ID列表
 * @param {string} [data.createUser] 创建用户
 * @param {number} [data.delFlag] 是否已删除(0否；1是)
 * @param {string} [data.estimatedContent] 估算内容
 * @param {number} [data.id] 主键
 * @param {string} [data.plannedCompletionTime] 计划完成时间 YYYY-MM-DD HH:mm:ss
 * @param {number} [data.projectId] 项目ID
 * @param {string} [data.responsiblePerson] 负责人
 * @param {string} [data.startTime] 开始时间 YYYY-MM-DD HH:mm:ss
 * @param {number} [data.totalDesignSettlementAmount] 设计结算总额
 * @param {string} [data.updateUser] 更新用户
 * @param {import("axios").AxiosRequestConfig} [config]
 * @returns {Promise<number>}
 */
export function designEstimateAdd(data, config) {
  return post("/designEstimate/add", data, config);
}

/**
 * 设计概算 控制器 / 设计概算 控制器删除设计概算
 * @param {object} params
 * @param {object} data
 * @param {number} params.id 设计概算ID
 * @param {import("axios").AxiosRequestConfig} [config]
 * @returns {Promise<number>}
 */
export function designEstimateDelete(params, data, config) {
  return postWithQueryParams("/designEstimate/delete", params, data, config);
}

/**
 * 设计概算 控制器 / 设计概算 控制器查询设计概算详情
 * @param {object} params
 * @param {number} params.id 设计概算ID
 * @param {import("axios").AxiosRequestConfig} [config]
 * @returns {Promise<DesignEstimate页面展示实体>}
 */
export function designEstimateDetail(params, config) {
  return get("/designEstimate/detail", params, config);
}

/**
 * 设计概算 控制器 / 设计概算 控制器导出
 * @param {object} data
 * @param {string} [data.actualCompletionTime] 实际完成时间 YYYY-MM-DD HH:mm:ss
 * @param {string} [data.createTime] 创建时间 YYYY-MM-DD HH:mm:ss
 * @param {string} [data.createUser] 创建用户
 * @param {number} [data.delFlag] 是否已删除(0否；1是)
 * @param {string} [data.estimatedContent] 估算内容
 * @param {number} [data.id] 主键
 * @param {number} [data.length] 分页大小
 * @param {number} [data.orderAsc] 排序方向
 * @param {string} [data.orderColum] 排序字段
 * @param {number} [data.pageIndex] 分页下标
 * @param {string} [data.plannedCompletionTime] 计划完成时间 YYYY-MM-DD HH:mm:ss
 * @param {number} [data.projectId] 项目ID
 * @param {string} [data.projectName] 项目名称
 * @param {string} [data.responsiblePerson] 负责人
 * @param {number} [data.start] 查询记录起始下标
 * @param {string} [data.startTime] 开始时间 YYYY-MM-DD HH:mm:ss
 * @param {number} [data.totalDesignSettlementAmount] 设计结算总额
 * @param {string} [data.updateTime] 更新时间 YYYY-MM-DD HH:mm:ss
 * @param {string} [data.updateUser] 更新用户
 * @param {import("axios").AxiosRequestConfig} [config]
 * @returns {Promise}
 * @author 陈凯
 */
export function designEstimateExport(data, config) {
  return post("/designEstimate/export", data, config);
}

/**
 * 设计概算 控制器 / 设计概算 控制器分页查询设计概算
 * @param {object} data
 * @param {string} [data.actualCompletionTime] 实际完成时间 YYYY-MM-DD HH:mm:ss
 * @param {string} [data.createTime] 创建时间 YYYY-MM-DD HH:mm:ss
 * @param {string} [data.createUser] 创建用户
 * @param {number} [data.delFlag] 是否已删除(0否；1是)
 * @param {string} [data.estimatedContent] 估算内容
 * @param {number} [data.id] 主键
 * @param {number} [data.length] 分页大小
 * @param {number} [data.orderAsc] 排序方向
 * @param {string} [data.orderColum] 排序字段
 * @param {number} [data.pageIndex] 分页下标
 * @param {string} [data.plannedCompletionTime] 计划完成时间 YYYY-MM-DD HH:mm:ss
 * @param {number} [data.projectId] 项目ID
 * @param {string} [data.projectName] 项目名称
 * @param {string} [data.responsiblePerson] 负责人
 * @param {number} [data.start] 查询记录起始下标
 * @param {string} [data.startTime] 开始时间 YYYY-MM-DD HH:mm:ss
 * @param {number} [data.totalDesignSettlementAmount] 设计结算总额
 * @param {string} [data.updateTime] 更新时间 YYYY-MM-DD HH:mm:ss
 * @param {string} [data.updateUser] 更新用户
 * @param {import("axios").AxiosRequestConfig} [config]
 * @returns {Promise<分页返回实体<DesignEstimate页面展示实体>>}
 */
export function designEstimateList(data, config) {
  return post("/designEstimate/list", data, config);
}

/**
 * 设计概算 控制器 / 设计概算 控制器更新设计概算
 * @param {object} data
 * @param {string} [data.actualCompletionTime] 实际完成时间 YYYY-MM-DD HH:mm:ss
 * @param {array<number>} [data.attachList] 附件ID列表
 * @param {string} [data.createUser] 创建用户
 * @param {number} [data.delFlag] 是否已删除(0否；1是)
 * @param {string} [data.estimatedContent] 估算内容
 * @param {number} [data.id] 主键
 * @param {string} [data.plannedCompletionTime] 计划完成时间 YYYY-MM-DD HH:mm:ss
 * @param {number} [data.projectId] 项目ID
 * @param {string} [data.responsiblePerson] 负责人
 * @param {string} [data.startTime] 开始时间 YYYY-MM-DD HH:mm:ss
 * @param {number} [data.totalDesignSettlementAmount] 设计结算总额
 * @param {string} [data.updateUser] 更新用户
 * @param {import("axios").AxiosRequestConfig} [config]
 * @returns {Promise<number>}
 */
export function designEstimateUpdate(data, config) {
  return post("/designEstimate/update", data, config);
}

/**
 * @template T
 * @typedef {Object} 分页返回实体
 * @property {T[]} content - 内容
 * @property {number} elementsNo
 * @property {number} limit
 * @property {number} number
 * @property {number} totalElements
 * @property {number} totalPages
 * @description 分页返回实体
 */

/**
 * @typedef {object} BusinessAttachDetailVO
 * @property {string} attKey 附件key
 * @property {number} attOrder 附件排序
 * @property {number} attSize 附件大小(单位:MB)
 * @property {string} attSizeString 附件大小
 * @property {string} attSuffix 附件后缀
 * @property {string} attUrl 附件url
 * @property {number} attachId 文件id
 * @property {number} attachmentType 文件类型
 * @property {number} businessId 业务ID
 * @property {string} businessType 业务类型
 * @property {string} createTime 创建时间
 * @property {string} createUser 创建用户
 * @property {boolean} delFlag 删除标识(false:否, true:是)
 * @property {number} directoryId 目录id
 * @property {string} filename 文件名称
 * @property {number} id 附件ID
 * @property {string} originalName 原始文件名
 * @property {string} remark 备注
 * @property {string} updateTime 修改时间
 * @property {string} updateUser 修改用户
 */

/**
 * @typedef {object} DesignEstimate页面展示实体 设计概算页面展示实体
 * @property {string} actualCompletionTime 实际完成时间
 * @property {array<BusinessAttachDetailVO>} attachList 附件
 * @property {boolean} canDelete 是否拥有删除权限
 * @property {boolean} canEdit 是否拥有编辑权限
 * @property {string} createTime 创建时间
 * @property {string} createUser 创建用户
 * @property {string} createUserDeptName 创建用户所属部门
 * @property {string} createUserRealName 创建用户真实姓名
 * @property {number} delFlag 是否已删除(0否；1是)
 * @property {string} estimatedContent 估算内容
 * @property {number} id 主键
 * @property {string} plannedCompletionTime 计划完成时间
 * @property {number} projectId 项目ID
 * @property {string} projectName 项目名称
 * @property {string} responsiblePerson 负责人
 * @property {string} startTime 开始时间
 * @property {number} totalDesignSettlementAmount 设计结算总额
 * @property {string} updateTime 更新时间
 * @property {string} updateUser 更新用户
 * @description 设计概算页面展示实体
 */
